package cn.lxh.system.domain;


import com.fasterxml.jackson.annotation.JsonInclude;
import lombok.Data;

import java.util.ArrayList;
import java.util.List;

/**
 * Menu菜单类
 */
@Data
public class Menu {

    /**
     * 主键
     */
    private Long id;

    /**
     * 菜单名称
     */
    private String name;

    /**
     * Vue组件路径
     */
    private String component;

    /**
     * 菜单路由地址
     */
    private String url;

    /**
     * 菜单图标
     */
    private String icon;

    /**
     * 菜单排序
     */
    private Integer index;

    /**
     * 上级菜单Id
     */
    private Long parentId;

    /**
     * 父菜单名称
     */
    private String parentMenuName;

    // 添加一个集合, 保存自己的所有子类型
    // 注意: 前端我们使用的是ElementUI的级联框, 默认子类型集合属性名就是children
    @JsonInclude(JsonInclude.Include.NON_EMPTY) // 类型树最后一级没有数据就不显示
    /** children表示父菜单的子菜单 */
    private List<Menu> children = new ArrayList<>();
}
